<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .fater {
            position: relative;
            margin: 100px auto;
            width: 500px;
            height: 250px;
            background-color: purple;
        }

        .son {
            position: absolute;
            top: 35px;
            left: 100px;
            width: 300px;
            height: 180px;
            background-color: pink;
        }
    </style>
</head>

<body>
    <div class="fater">
        <div class="son"></div>
    </div>
    <script>
        // Dom 事件流 三个阶段
        // 1.js代码中只能执行捕获或者冒泡其中一个阶段
        // 2.onclick（传统） 和 attachEvent（ie）只能得到冒泡阶段

        // 3.捕获阶段 如果addEventListener 第三个参数是true那么则处于捕获阶段 逗号隔开
        //document->html->body->fater->son
        var son = document.querySelector('.son')
        var fater = document.querySelector('.fater')
        // son.addEventListener('click', function () {
        //     alert('son')
        // }, true)
        // fater.addEventListener('click', function () {
        //     alert('fater')
        // }, true) 
        // 4.冒泡阶段 如果 addEventListener 第三个参数省略或者false那么则处于冒泡阶段 
        //son->fater->body->html->document
        fater.addEventListener('click', function () {
            alert('fater')
        }, false)
        son.addEventListener('click', function () {
            alert('son')
        }, false)
        document.addEventListener('click',function(){
            alert('document')
        })


    </script>
</body>

</html>